<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="../../vue.js"></script>
</head>

<body>
    <div class="box">
        <input type="text" v-model.lazy='msg'>
        <span>{{tip}}</span>
    </div>
    <script>
        // var vm = new Vue({
        //     el: '.box',
        //     data: {
        //         msg: '',
        //         tip: ''
        //     },
        //     methods: {
        //         handle() {
        //             setTimeout(() => {
        //                 if (this.msg === 'admin') {
        //                     this.tip = '用户名已存在'
        //                 } else {
        //                     this.tip = '此昵称可以使用'
        //                 }
        //             }, 1000)
        //         }
        //     },
        //     watch: {
        //         msg: function() {
        //             this.tip = '正在验证。。'
        //             this.handle()
        //         }
        //     }
        // })
        var vm = new Vue({
            el: '.box',
            data: {
                msg: '',
                tip: '',
            },
            methods: {
                handle(val) {
                    setTimeout(() => {
                        if (val === 'admin') {
                            this.tip = '用户名已经被使用'
                            document.querySelector('span').style.color = 'red'
                        } else {
                            this.tip = '此用户名可以使用'
                            document.querySelector('span').style.color = 'green'
                        }
                    }, 1000)
                }
            },
            watch: {
                msg: function(val) {
                    this.tip = '验证中'
                    document.querySelector('span').style.color = 'black'
                    this.handle(val)
                }
            }
        })
    </script>
</body>

</html>